## WHAT IS CLAIMED IS:

DOBBORK ABBY

3

Apparatus comprising: 1.

a cache including cache lines each of which is configured to store data; and

4 an eviction mechanism configured to evict data stored in

one of the cache lines hased on validity state information 5

associated with the data stored in the one cache line. 6

The apparatus of  $\phi$  laim 1 in which each of the cache lines 1

is configured to store data that corresponds to consecutive

addresses in a main memory.

The apparatus of claim 1 in which each cache line has

2 multiple portions.

The apparatus of claim 3 further comprising a storage for

storing validity bits that track the validity of respective

portions of the cache line.

The apparatus of claim 4 in which the validity bits are 1

set to a predefined value to indicate that the respective 2

portion has been written in full in one write transaction. 3

The apparatus of claim 5 in which the eviction mechanism 1

is configured/to evict the cache line when the validity bits

all have the predefined value. 3

1

- 7. The apparatus of claim 1 in which the eviction mechanism is configured to evict the data even if the cache is not full and data in other cache lines is not being evicted at the same time.
- 1 8. The apparatus of claim 1, further comprising a memory for
- storing the data evicted by the eviction mechanism.
- 1 9. The apparatus of claim 8, further comprising an
- 2 input/output device that generates the data stored in the
- 3 cache.

0035034,1257

- 10. Apparatus comprising:
- cache lines, each configured to store bytes of data that correspond to consecutive addresses in a main memory, each cache line corresponding to a group of validity bits, each of the validity bits tracking a portion of the cache line and being set to a predefined value when the tracked portion of
- 7 the cache line is fully written in one write transaction; and
- an eviction component configured to evict the bytes of
- 9 data stored in one of the cache lines when the group of
- validity bits corresponding to the cache line are all set to
- 11 the predefined value.
- 1 11. The apparatus of claim 10 in which cache lines are
- 2 disposed within a write cache memory of a computer chipset.

- 1 12. The apparatus of claim 11 in which the cache lines are compatible with a cache coherent protocol.
  - 13. A method comprising:
- receiving write transactions/associated with data to be
- 3 written;
- 4 storing the data into port/ions of a single cache line of
- 5 a cache, and
- evicting the data from the cache line when the cache line
- 7 is full of data according to stored validity information.
- 1 14. The method of claim 13/, further comprising writing the
- evicted bytes of data to a main memory.
  - 1 15. The method of claim/13, further comprising setting
- 2 validity bits to a predefined value when respective portions
- 3 of the cache line is  $w_{t}^{\dagger}$ itten in full.
- 1 16. The method of claim 13 in which the write transactions
- 2 are sent from an input/output device.
- 1 17. The method of k laim 16 in which each of the write
- 2 transactions sent from the input/output device writes a first
- number of data bytes to one of the cache lines, and the
- 4 eviction component evicts a second number of data bytes in one

6

second number.

Apparatus comprising:

a computer chipset having a ca/che memory configured to

store write data sent from an inpu/t/output device and a

mechanism configured to evict the write data from the cache

memory when a set of predefined /conditions are met. 5

The apparatus of claim 18 /in which the cache memory also 1

stores additional write data sent from an additional 2

input/output device, and the mechanism also configured to

evict the additional write data from the cache memory when the

set of predefined conditions are met.

The apparatus of claim 18 in which the cache memory is

compatible with a cache cherent protocol.

The apparatus of claim 18 in which the input/output

2 device initiates write #ransactions to send the write data,

and the mechanism is configured to combine the write data so 3

that the number of eviction operations performed to evict the 4

write data from the cache memory is less than the number of 5

write transactions initiated by the input/output device. 6

A method comprising: 1

-16-

initiating write transactions by an input/output device 2

to write data; 3

writing the data into a cache memory;

evicting the data from the cache memory; and

writing the data into a main memory.

23. The method of claim 22 in which the cache memory contains 1

cache lines configured to  $st \phi re$  data, each cache line 2

corresponding to consecutive addresses in main memory. 3

24. The method of claim 23 in which each cache line has 1

multiple portions, each portion corresponding to a validity

bit that tracks the status of the corresponding portion.

25. The method of claim 24 in which the validity bit is set

to a predetermined \*value responsive of the number of bytes of

data written into the corresponding portion.

The method  $\phi$ f claim 25 in which the evicting the data

from the cache memory comprises evicting the data when the

validity bits  $\phi$ orresponding to a cache line are all set to a

predefined value. 4

2

3